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BACKGROUND 

RELATED APPLICATION 

[0001 ] This application claims the benefit of U. S . Provisional Application 

No. 60/188,883, titled "Low Power Spread-Spectrum Receiver Architecture" filed 
on March 13,2000. 

1. Field of the Invention 

[0002] This invention relates to digital communication. In particular, the 

invention relates to global positioning system (GPS). 

2. Description of Related Art 

[0003] Global positioning system (GPS) has provided many useful civilian 

applications such as in-car navigation systems, automatic position reporting 
during emergency, low- visibility harbor operations, navigation systems for hikers, 
campers, and other recreational users. 

[0004] Existing techniques for designing GPS receivers have a number of 

drawbacks. First, the re-tracking circuit is either complex requiring significant 
amount of hardware, or slow resulting in poor performance. Second, power 
consumption is high and therefore the receiver is not suitable for low power 
applications. Third, the architecture may be difficult to interface to programmable 
processors. 

[0005] Therefore, there is a need to have an efficient architecture for GPS 

receivers to process GPS signals efficiently without incurring large power 
consumption. 



071811.P0O5 



-1- 



BRIEF DESCRIPTION OF THE DRAWINGS 



[0006] The features and advantages of the present invention will become 

apparent from the following detailed description of the present invention in which: 

[0007] Figure 1 is a diagram illustrating a system in which one 

embodiment of the invention can be practiced. 

[0008] Figure 2 is a diagram illustrating a base-band circuit shown in 

Figure 1 according to one embodiment of the invention. 

[0009] Figure 3 is a diagram illustrating a multiplier-free demodulator 

shown in Figure 2 according to one embodiment of the invention. 

[0010] Figure 4 is a diagram illustrating a low power passive correlator 

shown in Figure 2 according to one embodiment of the invention. 

[0011] Figure 5 is a diagram illustrating a correlator circuit shown in 

Figure 4 according to one embodiment of the invention. 

[0012] Figure 6 is a diagram illustrating the synchronous operation 

between the circularly shifted data register and the code register shown in Figure 4 
according to one embodiment of the invention. 

[0013] Figure 7 A is a diagram illustrating a range of correlation result 

using the actual ranges according to one embodiment of the invention. 

[0014] Figure 7B is a diagram illustrating a range of correlation result 

using the represented ranges according to one embodiment of the invention. 

[0015] Figure 7C is a diagram illustrating a mapping of the correlation 

result according to one embodiment of the invention. 

[0016] Figure 8 A is a diagram illustrating a pseudo random number 

generator and re-tracking circuit shown in Figure 2 according to one embodiment 
of the invention. 
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[0017] Figure 8B is a diagram illustrating a PN code generator shown in 

Figure 8 A according to one embodiment of the invention. 

[0018] Figure 8C is a diagram illustrating a tap selector shown in Figure 

8B according to one embodiment of the invention. 

[0019] Figure 9 is a diagram illustrating a control circuit for PN shifting 

according to one embodiment of the invention. 

[0020] Figure 1 0 is a diagram illustrating PV shifting technique as it 

applies to one code NCO generator according to one embodiment of the invention. 

[0021] Figure 1 1A is a diagram illustrating a Doppler circuit shown in 

Figure 2 according to one embodiment of the invention. 

[0022] Figure 1 IB is a diagram illustrating a carrier NCO base circuit 

shown in Figure 2 according to one embodiment of the invention. 

[0023] Figure 12 is a diagram illustrating a mixer circuit shown in Figure 

1 1 according to one embodiment of the invention. 

[0024] Figure 13 is a diagram illustrating an epoch processing circuit 

shown in Figure 2, which controls the I and Q memory circuits according to one 
embodiment of the invention. 

[0025] Figure 14 is a diagram illustrating a memory circuit shown in 

Figure 13 according to one embodiment of the invention. 

DESCRIPTION 

[0026] In the following description, for purposes of explanation, numerous 

details are set forth in order to provide a thorough understanding of the present 
invention. However, it will be apparent to one skilled in the art that these specific 
details are not required in order to practice the present invention. In other 
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instances, well-known electrical structures and circuits are shown in block 
diagram form in order not to obscure the present invention. 

[0027] One embodiment of the present invention includes a circular shift 

register, K storage elements, and a code register. The circular shift register having 
N data samples circularly shifts a first data sample of the N data samples into a 
data position at a first clock frequency. The N data samples correspond to signal 
received from one of K satellites in a global positioning system (GPS). The N 
data samples are loaded into the circular shift register at a second clock frequency. 
The K storage elements store K code sequences, respectively. Each of the K code 
sequences has N code samples and includes a first code sample being written at a 
code position corresponding to the data position at a third clock frequency. The K 
storage elements correspond to the K satellites. The code register stores the N 
code samples loaded from one of the K storage elements at a fourth clock 
frequency. The fourth clock frequency is K times faster than the first clock 
frequency. 

[0028] While this invention has been described with reference to 

illustrative embodiments, this description is not intended to be construed in a 
limiting sense. Various modifications of the illustrative embodiments, as well as 
other embodiments of the invention, which are apparent to persons skilled in the 
art to which the invention pertains are deemed to lie within the spirit and scope of 
the invention. 

[0029] The A/D converter 130 converts the analog signal from the RF 

front end circuit 120 into digital data for digital processing in subsequent stages. 
The A/D converter 130 operates with a sampling frequency at 16*f>. The 
sampling frequency is selected to provide adequate anti-aliasing without incurring 
complexity and costs to the system 100. A sample-and-hold device (not shown) 
may be used to hold the analog signal during the A/D conversion. The sample- 
and-hold device acts like a sampler operating at the sampling frequency. The 
word length of the A/D converter 130 depends on the characteristics of the signal 
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and the requirements of the system. In one embodiment, the AID converter 130 
has a word size of one bit. When the A/D converter 130 has a word size of one 
bit, it can be implemented as a hard limiter using an operational amplifier as a 
comparator. The output of the comparator is one of two logic levels depending on 
whether the analog sample is greater or below a predetermined threshold value. 
The comparator output is the digitized input sample and is latched into a flip-flop 
clocked at a sampling clock signal. In one embodiment, this sampling clock 
signal is sixteen times the nominal frequency f 0 of 1 .023 MHz. The digitized 
input samples are then fed to the base-band circuit 140 for base-band processing. 

[0030] The base-band circuit 140 is the main section to process the 

digitized signal, or samples, to provide correlation results to the processor 150. 
The base-band circuit 140 uses a multi-channel multiplexing scheme and a spread 
spectrum architecture. The base-band circuit 140 has a number of novel features 
to be described later. These features include efficient processing, simple 
implementation, and low power. The base-band circuit 140 processes the input 
signal from a number of satellites in the GPS. In one embodiment, the number of 
satellites is twelve. The base-band circuit 140 employs a parallel mechanism to 
process all twelve channels corresponding to the twelve satellites. 

[0031] The processor 1 50 is any processor or processing element that is 

capable of executing instructions and communicating with input/output devices or 
circuits. The processor 150 generates control information to the base-band circuit 
140 and interfaces to input/output devices or elements. The input/output devices 
or elements may include any suitable input/output. Examples of the input/output 
devices or elements include user's keyboard, display, serial communication 
interface, and parallel input/output processor. The processor 150 may include a 
central processing unit (CPU), a memory, and any appropriate interfacing devices. 
Examples of the CPU include general-purpose microprocessors with any 
architecture (e.g., superscalar, vector processor, reduced instruction set computer), 
micro-controllers, digital signal processors, embedded processors. 
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[0032] The oscillator 1 60 provides a basic clock signal to the base-band 

circuit 140. The basic clock signal is then divided into many clock signals having 
various frequencies compatible with the GPS timings. In one embodiment, the 
basic clock signal has a frequency of 48*f 0 . The base-band circuit 140 derives 
other clock signals vising the basic clock signal. These clock signals are used to 
synchronize the elements and/or devices in the base-band circuit 140. The base- 
band circuit 140 also provides clock and/or timing signals to the RF front end 
circuit 120. 

[0033] Figure 2 is a diagram illustrating the base-band circuit 140 shown 

in Figure 1 according to one embodiment of the invention. The base-band circuit 
140 includes a multiplier-free demodulator 220, a low-power passive correlator 
230, a pseudo random number (PN) generator and re-tracking circuit 240, a 
Doppler circuit 250, an epoch processing circuit 260, and a clock generator 270. 

[0034] The multiplier-free demodulator 220 is a base-band down converter 

to bring the signal to zero IF. This is accomplished by multiplying the input 
samples with sine and cosine of angles differing by 90° to split into in-phase (I) 
and quadrature (Q) components. In one embodiment, the signal is over sampled at 
a sampling frequency that is 4q (where q is an integer) times higher than the signal 
frequency. An efficient mixer is used to replace the multiplier by an equivalent 
operation. Then, the resulting samples are decimated to keep the samples within a 
desired frequency range. 

[0035] The low-power passive correlator 230 correlates the decimated 

samples from the multiplier-free demodulator 220 with PN code samples which 
are locally generated. The passive correlator 230 is a de-spreader to recover the 
transmitted signal samples at the proper frequency range. The PN code samples 
are part of a PN sequence. In one embodiment, the PN sequence has a length of 
1023. The passive correlator 230 works with two phases per chip and checks 
blocks of 2N phases for synchronization for all K satellite channels. N is an 
integer selected so that the PN sequence can be processed over a multiple of times. 
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Possible values for N to allow an evenly divisible number of times from the PN 
sequence length of 1023 are N = 3, 11, and 31. The values 1023, 3, 11, and 31 are 
for illustrative purposes only. The choice of 3 provides a very short turn-off time. 
The choice of 31 increases the hardware complexity. The choice of 1 1 is a 
compromise between hardware complexity and turn-off time. As is known by one 
skilled in the art, any other numbers can be used. Correlation between the data 
samples and the PN code samples typically involves shifting operations to shift 
the data samples and the PN code samples in synchrony. Each time new samples 
are shifted in a multiplication is performed on the newly shifted samples to 
produce a product. For a block of N samples, there are N products. Thereafter, an 
addition is performed on the N products to produce a correlation result for that 
block. The passive correlator 230 reduces power consumption caused by shift 
registers by using a multiplexing data writing technique. In addition, the 
multiplication and addition are much simplified to keep the correlation result 
within a small number of bits. In one embodiment, the correlation result or output 
of the passive correlator 230 is 6-bit including a sign bit. 

[0036] The pseudo random number (PN) generator and re-tracking circuit 

240 generates the PN code samples to the passive correlator 230. To distinguish 
various satellites, a unique PN code is assigned to each satellite. These codes are 
chosen for maximum orthogonality to maximize detectability. The PN code 
samples are generated for N satellites sequentially. The generation of the PN code 
samples is clocked by a numerically controlled oscillator (NCO). For re-tracking, 
the NCO can advance or slip over a number of chips. The number of chips 
advanced or slipped may be any number. In one embodiment, this number ranges 
from 0 to 5.5 (e.g., 1, 2, 3, 4, 5, or 5.5). The PN generator and re-tracking circuit 
240 is controlled by the processor 150. The processor 150 determines how many 
chips the PN code have to be shifted and loads an appropriate number into the PN 
generator and re-tracking circuit 240 and a shift command. 

[0037] The Doppler circuit 250 removes the Doppler shifts on the 

correlation outputs from the passive correlator 230. This is performed by another 
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mixer circuit to mix the de-spreaded samples with the sine and cosine values 
provided by a carrier NCO for a selected satellite. For N satellites, N carrier 
NCO's are used. The Doppler circuit 250 sequences through the N carrier NCO's. 

[0038] The epoch processing circuit 260 processes the data at the end of 

each epoch. At the end of each epoch, the PN code samples are filled with all l's. 
The epoch processing circuit 260 sequences through the N satellite channels. The 
result samples are accumulated or added to provide final result for each satellite. 
A double-buffered memory scheme is used to allow storing one set of samples in a 
first memory while a set of results is read out to a second memory. The processor 
150 then can access the second memory to retrieve the results for further 
processing. 

[0039] The clock generator 270 generates various clock signals to be used 

by other circuits in the base-band circuit 140. In one embodiment, the clock 
generator 270 receives the basic clock signal at 48 times the nominal frequency fO. 
From this basic clock signal, the clock generator 270 generates all or a subset of 
the following clock signals: a sampling clock signal at 24*f 0 , a clock signal at 
16*f 0 , a clock signal at 8*f 0 , a clock signal at 4*f 0 , and a clock signal at 2*f 0 . The 
clock generator 270 may be implemented by a number of methods. One method is 
to use a counter clocked by the basic clock signal and some logic gates. The 
outputs of the counter are the divide-by-K clock signals that have frequencies of 
24*f 0 , 16*f 0 , 8*f 0 , 4*f 0 , and 2*f 0 . To prevent clock skewing, additional delay 
elements may be inserted as appropriate. 

[0040] Figure 3 is a diagram illustrating the multiplier-free demodulator 

220 shown in Figure 2 according to one embodiment of the invention. The 
demodulator 220 includes a gating circuit 310, a demultiplexer 320, an 
integrator/decimator 330, a mapper 340, and a reset circuit 350. 

[0041] The gating circuit 3 1 0 essentially performs a multiplication of the 

input samples with the sine and cosine values without using an actual multiplier. 
As discussed earlier, the input samples are one-bit samples clocked at the 
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sampling clock signal having a frequency of 16*f 0 . The input samples are then 
multiplied by two-bit sine and cosine values at 4*f 0 . This multiplication is 
equivalent to multiplication by two consecutive +l's and two -1 's. Furthermore, 
since the input samples are one-bit having logic values of 0 and 1, the 
multiplication can be efficiently performed by an exclusive OR operation. The 
gating circuit includes an exclusive OR gate 312 and a frequency divider 314. 
The exclusive OR gate 312 performs the multiplication between the input samples 
and the sine/cosine values of two consecutive +1 's and two -1 's. The sine and 
cosine values can be encoded as +1 's and O's. The frequency divider 314 
generates the sine/cosine values of +1 's and O's. The frequency divider 314 can 
be implemented as two flip-flops connected in cascade to effectively divide the 
sampling clock by four to provide a clock signal having a frequency of 4*f 0 . The 
frequency divider 314 also generates two complementary clock signals at 
frequency of 8*f 0 : one is true form and one is in complementary form. These two 
complementary 8*f 0 clock signals are used by the demultiplexer 320. The gating 
circuit 314 generates a gated input sample at the frequency of the sampling clock 
signal. 

[0042] The demultiplexer 320 essentially splits the mixed input samples 

into in-phase and quadrature components. This is performed by demultiplexing 
the gated input sample into two signals. The demultiplexer 320 includes two 
synchronizers 322 and 324. The synchronizers 322 and 324 synchronizes the 
gated input sample by the true and complementary form of the 8*fo clock signal, 
respectively, to generate the in-phase and quadrature samples. Since the 
synchronizers 322 and 324 are clocked by the 8*f 0 clock signal, they essentially 
down sample the gated input samples at 8*f 0 frequency by a factor of two. 

[0043] The integrator/decimator 330 further down samples or decimates 

the in-phase and quadrature samples by integrating them in an integration interval. 
The integration interval is selected to be equivalent to a four-sample interval so 
that the down sampling bring the gated input samples to 2*f 0 samples/sec. This 
can be done effectively by counting the number of 1 's in the gated input sample in 
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a 4-sample interval. The integrator/decimator 330 includes two K-bit counters 
332 and 334 to count the number of 1 's in the in-phase and quadrature samples 
from the synchronizers 322 and 324, respectively. The K-bit counters 332 and 
334 are reset by a reset signal generated from the reset circuit 350. This reset 
signal is to start a new integration interval. The K-bit counters 332 and 334 
generate in-phase and quadrature decimated samples, respectively, to the mapper 
340. K is selected to ensure that the count value can cover the possible range of 
numbers. Note that the in-phase or quadrature sample is one-bit. Therefore, the 
possible numbers of bit l's in the in-phase or quadrature sample in a 4-sample 
integration interval are 0, 1, 2, 3, and 4. If +1 's and -l's are used to encode the 
integrated samples, these numbers are equivalent to -2, -1, 0, +1, and +2. To 
represent these numbers, K would have been 3. In other words, the effect of down 
sampling is that each sample becomes a three-bit sample. 

[0044] The mapper 340 maps the in-phase and quadrature decimated 

samples into in-phase and quadrature demodulated samples, respectively. The in- 
phase and quadrature demodulated samples have L bits where L is less than K. 
This mapping reduces the number of bits to represent the in-phase and quadrature 
decimated samples for more efficient processing. This mapping acts like a lower 
and upper hard limiter on the {0, 1, 2, 3, 4} range to limit the lower value to 1 and 
the upper value to 3. In other words, 0 and 1 are mapped into 1, 2 is mapped into 
2, 3 and 4 are mapped into 3. The mapper 340 includes two combinational 
circuits 342 and 344 to perform this mapping for the in-phase and quadrature 
decimated samples, respectively. The three input A, B, and C of the decimated 
samples are mapped into two outputs B N and Cn as shown in Figure 3. The two- 
bit in-phase and quadrature demodulated samples are fed to the passive corrrelator 
230 for further processing. 

[0045] The reset circuit 350 resets the integrator/decimator 330 at the end 

of each integration interval. The reset circuit 350 includes an M-bit counter 362 
and an OR gate 364. 
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[0046] The M-bit counter 362 is clocked by the true form of the 8*f 0 clock 

signal and is reset by a system reset signal. The M-bit counter 362 generates a 
terminal count signal when the maximum count is reached. The OR gate 364 
performs an OR operation between the terminal count signal of the M-bit counter 
362 and the reset signal. When the reset signal or the terminal count signal is 
asserted, the reset circuit 350 asserts the reset signal to reset both the K-bit 
counters 332 and 334 in the integrator/mapper 330. M is selected to correspond to 
the integration interval. In one embodiment, the integration interval is equivalent 
to 4-sample interval and M is equal to 2. 

[0047] Figure 4 is a diagram illustrating the low power passive correlator 

230 shown in Figure 2 according to one embodiment of the invention. The 
passive correlator 230 includes a load register 410, a circular shift register 420, a 
correlator circuit 430, a code register 440, N storage elements 452i to 452 N , and a 
write circuit 460. Note that for simplicity, only one passive correlator is shown. 
For completeness, two passive correlators are used to process the in-phase and 
quadrature components. 

[0048] The load register 410 receives the two-bit in-phase and quadrature 

demodulated samples from the demodulator 220. The load register 410 transfers 
its contents to the circular shift register 420 at a clock rate equivalent to 2*f 0 / M 
where M is the number of demodulated samples to be stored in the load register 
410. hi one embodiment, the load register 410 has twenty-two elements (or M= 
22) to store a block of 1 1 samples of two phases. The selection of the number 1 1 
is explained above. The load register 410, therefore, is organized to store a total 
of forty-four bits. For a nominal value of f 0 = 1 .023 MHz, the transfer rate from 
the load register 410 to the circular shift register 420 is 93 KHz or a period of 
10.75 usee. 

[0049] The circular shift register 420 circularly shifts a demodulated 

sample into a data position at the 2*f 0 clock rate. In one embodiment, the shift is 
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left shift and circular in that the leftmost sample is shifted into the rightmost 
position. 

[0050] The correlator circuit 430 computes a correlation result from the 

demodulated samples and the code samples provided by the code register 440. 
During the 2*f 0 clock period, the correlator circuit 430 computes correlation 
results for twelve satellites. 

[0051] The code register 440 stores M PN code samples transferred from 

one of the N storage elements 452! to 452 N . The N storage elements 452i to 452 N 
store N PN code sequences corresponding to N satellites. All N storage elements 
452i to 452 N operate in synchrony. The N PN code sequences come from the PN 
generator and re-tracking circuit 240 (Figure 2). The writing of the N PN code 
samples into the N storage elements 45 2 1 to 452 N is synchronized with the circular 
shifting of the circular shift register 420 so that correct phase values are correlated 
with correct code samples. For each storage element, a code sample is written 
into the storage element at a code position corresponding to a data position of the 
corresponding demodulated sample in the circular shift register 420. This writing 
is essentially equivalent to shift the N storage elements 452i to 452 N 
synchronously with the circular shifting of the circular shift register 420. By 
avoiding using N shift registers to shift N PN code sequences, significant 
reduction of power consumption is achieved. The synchronous operation between 
the circular shift register 420 and the N storage elements 452 1 to 452 N is explained 
more in Figure 6. The N storage elements 452t to 452 N may be implemented as N 
rows of flip-flops where each row has M flip-flops, N registers with selectable 
data write, or N rows of a static random access memory (RAM), or any other 
suitable storage devices. 

[0052] The write circuit 460 writes N code samples into the N storage 

elements 452i to 452 N at the N code positions corresponding to the data position 
of the circular shift register 420. The write circuit 460 includes a decoder 470 to 
enable the N code positions for writing synchronously with the shifting of the 
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circular shift register 420. If each of the N storage elements 452i to 452 N is 
implemented by M flip-flops, the decoder 470 essentially enables the gating of the 
clock signal that clocks the flip-flops. 

[0053] After a short turn-off time, the passive correlator 230 allows for re- 

tracking in principle within 10.75 \xs if the PN code has drifted away +/- 5.5 chips. 
That is equivalent to about 5.5 |_is change in one pseudo range. Assuming 300,000 
km/s speed of light that corresponds to a satellite moving 1.67 km toward or away 
from the receiver, and assuming that the speed of a satellite is 3 km/s, then under 
worst-case conditions without further signal processing, it is possible to turn off 
the receiver for 0.5 second. This turn-off time results in a large reduction of 
power consumption. In reality, the correlator output has to be integrated over 
many cycles to be valid. The satellite movement also follows certain predictable 
paths. It is then possible despite the multiple integration requirements to keep the 
GPS unit turned off for many seconds. 

[0054] Figure 5 is a diagram illustrating the correlator circuit 430 shown 

in Figure 4 according to one embodiment of the invention. The correlator circuit 
430 includes M mappers 510i to 510 M , an adder 520, a subtractor 530, and a 
register 540. 

[0055] The M mappers 5 1 0i to 5 1 0 M map the M two-bit demodulated 

samples and the corresponding M one-bit code samples in the code register 440 to 
generate M two-bit mapper outputs. The mapping is essentially equivalent to a 
multiplication of the demodulated sample with the code sample. In addition, the 
mapping also provides a proper bit representation for the data to simplify the 
implementation. Each of the M mappers 510i to 510 M is implemented by a 
combinational circuit including an exclusive-OR gate, an OR gate, and an inverter 
as shown in Figure 5. This mapping is further explained in Figures 7 A through 
7C. 

[0056] The adder 520 adds the M two-bit mapper outputs to generate a 

result sum. The subtractor 530 subtracts a bias value from the result sum to 
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generate the correlation result. The register 540 stores the correlation result at the 
sampling clock rate. 

[0057] Figure 6 is a diagram illustrating the synchronous operation 

between the circularly shifted data register and the code register shown in Figure 4 
according to one embodiment of the invention. 

[0058] At time t, the circular shift register 420 is parallel loaded with 1 1 

pairs of demodulated samples. Each pair includes two phases a and b. The 22 
samples are (a n , b n ), (a n+ i, K+i), . . ., (a n+ io, b n+ i 0 ). At the same time, the code 
register 440 is loaded with the corresponding 1 1 pairs of code samples from one 
of the N storage elements 452 1 to 452 N . The 22 code samples are (s m , t m ), (s m +i, 

Wl), • • - , (Sm+lOj t m+ io). 

[0059] At time t+At, the circular shift register 420 circularly shifts the 22 

samples so that each sample is shifted to the left and the left most sample b n+ i 0 is 
shifted to occupy the rightmost position. At the same time, the writing circuit 460 
(Figure 4) writes to the rightmost position of the N storage elements 452 1 to 452 N . 
Then the code register is loaded with one of the N storage elements 452i to 452 N . 
Note that the code register 440 is loaded with contents of all the N storage 
elements corresponding to the N satellites within the At time interval. The 
remaining code samples remain the same. 

[0060] At time t+2 At, the circular shift register 420 circularly shifts the 22 

samples so that each sample is shifted to the left and the left most sample a n+ i 0 is 
shifted to occupy the rightmost position. At the same time, the writing circuit 460 
(Figure 4) writes to the next rightmost position of the N storage elements 452i to 
45 2 N . Then the code register is loaded with one of the N storage elements 452 1 to 
452 N . The remaining code samples remain the same. The process continues when 
all M code samples are written into the N storage elements 452i to 452 N . At time 
t+kAt, N code samples are written into the code position k while the other code 
positions contain the same code samples. Thereafter, a new sequence of M 
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demodulated samples is transferred to the circular shift register 420 and the 
process repeats. 

[0061] By using N storage elements 452 x to 452 N and a clever writing 

mechanism, it is not necessary to use N shift registers. This results in a significant 
reduction of power consumption. 

[0062] Figure 7 A is a diagram illustrating a range of correlation result 

using the actual ranges according to one embodiment of the invention. In this 
illustrative example, M = 22 corresponding to two phases of the 1 1 samples. 

[0063] The demodulated sample may be one of -1 , 0, and +1 values. The 

PN code sample maybe one of-1 and +1. When multiplied together, the product 
maybe one of-1, 0, and +1 result. When added together, the 22 products may 
form a sum having a range of {-22, +22}. 

[0064] Figure 7B is a diagram illustrating a range of correlation result 

using the represented ranges according to one embodiment of the invention. 

[0065] The demodulated samples are encoded to have representations of 

01,10, and 1 1, corresponding to -1, 0, and +1, respectively. The PN code sample 
is represented by 0 and 1, corresponding to -1 and +1, respectively. The mapper 
M maps the product to 1, 2, and 3, corresponding to -1, 0, and +1, respectively. 
The adder produce a sum in the range of {+22, +66} . The subtracter subtracts a 
bias value of 22 from the sum so that the result has a range of {0, +44}. This 
range can be represented by a 6-bit result. 

[0066] Figure 7C is a diagram illustrating a mapping of the correlation 

result according to one embodiment of the invention. 

[0067] The mapping is equivalent to a multiplication of-1 , 0, +1 and -1 , 

+1 . The mapping implements the following multiplication table. 

Data sample Code sample Product 



071811.P005 



-15- 



VL ^ If 


0 (-1) 


01 (+1) 


01 (-1) 


1 (+1) 


11 (-1) 


10 (0) 

IV \Vf 


0 (-1) 


10 (0) 


10(0) 


1(+1) 


10(0) 


11 (+1) 


0(-l) 


11 (-1) 


11 (+1) 


1(+1) 


01 (+1) 



[0068] Note that the values inside parentheses represent the actual values. 

Other mappings are possible. The mapping can be implemented by a 
combinational circuit for the mapper shown in Figure 5. 

[0069] Figure 8A is a diagram illustrating the pseudo random number 

(PN) generator and re-tracking circuit 240 shown in Figure 2 according to one 
embodiment of the invention. The PN generator and re-tracking circuit 240 
includes a control circuit 810, N accumulators 820i to 820N, N increment registers 
830i to 83 On and a PN generator 840. 

[0070] The control circuit 810 generates at least a channel enable signal 

based on control information from the processor 150 (Figure 1) at the 8*fo 
frequency. For N satellites, the control circuit 810 generates N channel enable 
signals. The control information includes at least one of channel select 
information, an initial count, an increment value, and PN command. 

[0071 ] Each of the N accumulators 820] to 820 N generates a PN clock 

signal corresponding to the selected satellite channel based on the increment 
value. The PN clock signal is used by the PN generator 840. Each of the N 
accumulators 820i to 820n is enabled by a corresponding channel enable signal 
from the control circuit 810. 



07181 1.P005 



-16- 



[0072] Each of the N increment registers 830i to 83 0 N stores an increment 

value of the corresponding satellite channel at the 8*f 0 frequency. The processor 
150 selects a satellite channel by writing the channel select information and writes 
the increment value to the selected channel. In one embodiment, each of the N 
increment registers 830i to 830 N has 16 bits. 

[0073] The PN generator 840 generates N PN code samples to the passive 

correlator 230 based on the channel select information. As discussed earlier, each 
of the N satellites has a unique PN code sequence. During normal operation, the 
PN generator 840 operates at the nominal fO frequency. During re-tracking, the 
PN codes are shifted back and forth based on the individual PN clock signals 
provided by the N accumulators 820] to 820 N - The PN generator 840 includes N 
PN code generators 845 1 to 845 N clocked by the PN clock signals from N 
accumulator 820i to 820 N , respectively. 

[0074] Figure 8B is a diagram illustrating the PN code generator 845 k 

shown in Figure 8A according to one embodiment of the invention. The PN code 
generator 845 k includes a Gl coder 850, a G2 coder 860, an AND gate 865, a tap 
selector 870, and an exclusive OR gate 875. 

[0075] The Gl coder 850 generates a Gl code sequence. The Gl coder 

850 includes a shift register 852 and an exclusive OR gate 854. The shift register 
852 has ten elements and shifts the code bits to the right. The shift register 852 is 
clocked by the PN clock signal k from the corresponding accumulator 820k 
(Figure 8A). The processor 150 initially loads the shift register 852 with all l's. 
The exclusive OR gate 854 is a two-input exclusive OR gate which perform an 
exclusive OR operation on elements 3 and 10 of the shift register 852. The output 
of the exclusive OR gate goes back to the input of the shift register 852. 

[0076] The G2 coder 860 includes a shift register 862 and an exclusive OR 

gate 864. The shift register 862 has ten elements and shifts the code bits to the 
right. The shift register 862 is clocked by the PN clock signal k from the 
corresponding accumulator 820 k (Figure 8A). The processor 150 initially loads 



07181 1.P005 



-17- 



the shift register 862 with all 1 's. The exclusive OR gate 864 is a six-input 
exclusive OR gate which perform an exclusive OR operation on elements 2, 3, 6, 
8, 9, and 10 of the shift register 862. The output of the exclusive OR gate 864 
goes back to the input of the shift register 862. 

[0077] The AND gate 865 is a ten-input AND gate which performs an 

AND operation on all ten elements of the shift register 862. When all the ten 
elements of the shift register 862 contain all 1 's, an epoch event has occurred, i.e., 
an epoch is ended and a new epoch begins. The output of the AND gate 865, 
therefore, provides an indication that an epoch has elapsed. This epoch event 
signal is used by the epoch control circuit in the epoch processing circuit 260 
(Figure 6). 

[0078] The tap selector 870 selects the taps in the shift register 862 of the 

G2 coder 860 to be used in generating the PN code k out of the PN generator 840 
(Figure 8A). The selected taps in the shift register 862 are unique for each 
satellite. The processor 150 writes the selection to the tap selector 870. 

[0079] The exclusive OR gate 875 performs an X-OR operation on the 

output of the Gl coder 850 and the output of the tap selector 870 to generate the 
PN code k. 

[0080] Figure 8C is a diagram illustrating the tap selector 870 shown in 

Figure 8B according to one embodiment of the invention. The tap selector 870 
includes a tap register 875, a mask circuit 880, and an exclusive OR gate 890. 

[0081] The tap register 875 has ten elements corresponding to the ten 

elements of the shift register 862 in the G2 coder 860. The tap register 875 is 
written by the processor 150 to select the P taps unique to a satellite. In one 
embodiment, P = 2. The mask circuit 880 masks the non-selected taps from the 
shift register 862 using the tap register 875. The mask circuit 880 includes ten 
AND gates 8851 to 88510. Each of the AND gate ANDs a cell of the tap register 
875 with a corresponding cell of the shift register 862. If any of the cells of the 
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G2 coder 860 are selected, those cells are tapped into the exclusive OR gate 890. 
The output of the X-OR gate 890 goes to the exclusive OR gate 875. 

[0082] Figure 9 is a diagram illustrating the control circuit 810 for PN 

shifting technique as it applies to one code NCO generator according to one 
embodiment of the invention. The control circuit 810 includes a decoder 910, a 
channel enable register 920, a counter 930, and a logic circuit 940. 

[0083] The decoder 910 receives the channel select information from the 

processor 150 (Figure 1) and generates N decoded signals from the channel select 
information. For N= 12, the decoder 910 is a 4-to-12 decoder. The channel 
enable register 920 stores the decoded signals to generate N channel enable signals 
at a 8*f0 frequency. The loading of the channel enable register 920 is enabled by 
the logic circuit 940. The channel enable register 920 is asynchronously reset by 
the logic circuit 940. 

[0084] The counter 930 updates a count for the amount of PN shifting 

required from the initial count at the 8*fb clock signal. When the count reaches a 
terminal count, the counter 930 generates a terminal signal to reset the channel 
enable register 920. In one embodiment, the counter 930 is an 8-bit down counter 
to count from the initial count to zero, i.e., the terminal count is zero. The 
processor 150 writes the initial count to the counter 930. 

[0085] The logic circuit 940 generates a load signal and a reset signal. 

The load signal is to load the counter 930 and the channel enable register 920. 
The reset signal is to reset the channel enable register 920. 

[0086] Figure 10 is a diagram illustrating the PN shifting technique as it 

applies to one code NCO generator according to one embodiment of the invention. 
The accumulator 820 includes an accumulating register 1010, an adder 1020, and 
an adder control circuit 1030. 

[0087] The accumulating register 1010 stores a NCO value at a current 

cycle of the 8*f 0 clock signal. The NCO value provides the PN clock signal for 
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the selected satellite channel. In one embodiment, the accumulating register 1010 
has 28 bits and the most significant bit of the NCO value provides the PN clock 
signal. 

[0088] The adder 1 020 adds the increment value from the corresponding 

increment register to the NCO value from the accumulating register 1010 to 
generate a sum representing the NCO value loaded into the accumulating register 
1010 in the next clock cycle of the 8*fo clock signal* 

[0089] The adder control circuit 1030 is a combinational circuit to 

generate an enable command, a left shift command, and a right shift command to 
the adder 1020 using the PN command provided by the processor 150 and the 
channel enable signal from the channel enable register 920 (Figure 9). When the 
channel enable signal is de-asserted indicating the satellite channel is not selected, 
the adder control circuit asserts the enable command which asserts bit 25 of the 
adder 1020. The bit 25 is selected to correspond to a value 2 25 which is increment 
corresponding to the PN generator frequency of 1 .023 MHz. When the channel 
enable signal is asserted indicating the satellite channel is selected, the adder 
control circuit 1030 asserts a left command when the shift command is LOW and 
asserts a right command when the shift command is HIGH. The left and right 
commands assert bits 24 and 26, respectively. 

[0090] The accumulator 820 overflows at the required frequency of f g . In 

one embodiment, the most significant bit (MSB) of the accumulator output is a 
square wave of f g frequency. Let n = 28 and m = 16 be the number of bits for the 
accumulating register and the increment value. Let M be the marching value. Let 
f c = 8*f 0 where f 0 = 1.023 MHz. Then: 

f g = Mf c /2 n (1) 

f g = 1.023 x 10 6 Hz = M*8*(1.023 x 10 6 Hz)/2 28 (2) 
M = 2 25 (3) 
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[0091] If the frequency fg is advanced by adding to the marching value, 

then the time it takes to advance by q chips can be calculated as follows. 

q = [(M + AM)*f c / 2 n - M*f c / 2 n ]*t (4) 

t = q /{AM*f c )/2 n = (q/fg)*(M/AM) (5) 

[0092] Using the above equations, the time and the number of NCO clock 

cycles needed to advance or slip up to +/- 5.5 chips can be calculated as follows: 

f c = 8*f 0 = 8.184 MHz, m = 16, n =28, M = 2 25 

For f g = 1.023 MHz: 

Number of chips advanced T (us) NCO clock cycles 



1 0.977 8 

2 1.955 16 

3 2.932 24 

4 3.910 32 

5 4.887 40 
5.5 5.376 44 
For f g = 2*1.023 MHz: 

Number of chips slipped T (us) NCO clock cycles 

1 1.955 16 

2 3.910 32 

3 5.065 48 
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4 



7.820 



64 



5 9.770 80 

5.5 10.75 88 

[0093] The NCO marching value can be used to advance or slip precisely 

to within +/- 5.5 chips by counting the number of NCO clock cycles all within less 
than 1 1 u,s. It is also possible to totally sty NCO clock for a number of cycles to 
compensate for the slippage. 

[0094] Figure 1 1 A is a diagram illustrating the Doppler circuit 250 shown 

in Figure 2 according to one embodiment of the invention. The Doppler circuit 
250 includes a carrier NCO 1 1 10, a look up table 1 120, two registers 1 125 and 
1 127, and a mixer circuit 1110. 

[0095] The carrier NCO generates a carrier NCO value to select sine and 

cosine values from the look up table 1 120. The carrier NCO includes a decoder 
1 1 12, N carrier NCO base circuits 1 1 14i to 1 1 14 N , a multiplexer 1 1 16, and a 
counter 1118. The decoder 1112 generates decoded signals from the channel 
select information. The decoded signals correspond to the satellite channels. 
Each of the carrier NCO base circuits 1 1 14i to 1 1 14 N provides a carrier NCO 
value corresponding to the selected satellite channel. In one embodiment, the 
carrier NCO value is 3-bit. The multiplexer 1 1 16 selects one of the 3-bit N carrier 
NCO values based on the select signal generated by the counter 1118. The 
counter 1118 sequences through the N channels and clocked by the sampling 
clock signal at 24*fo frequency. 

[0096] The look up table 1 120 generates the coefficients based on the 

carrier NCO value. The coefficients include the sine and cosine values to be used 
by the mixer circuit 1130. In one embodiment, the sine and cosine values are 
stored in the look up table 1 120 according to the 3-bit carrier NCO values as 
follows. 
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Carrier NCO value 


Sine value 


Cosine value 


000 


000 (0) 


Oil (3) 


001 


010 (2) 


010(2) 


010 


Oil (3) 


000 (0) 


Oil 


010 (2) 


110 (-2) 


100 


000 (0) 


111 (-3) 


101 


110 (-2) 


110 (-2) 


110 


111 (-3) 


000 (0) 


111 


110 (-2) 


010 (2) 



[0097] The two registers 1 125 and 1 127 store the sine and cosine values 

from the look up table 1 120 at the sampling clock signal of 24*f 0 frequency. 

[0098] The mixer circuit 1130 mixes the demodulated sample from the 

passive correlator 230 (Figure 2) with the coefficients (e.g., the sine and cosine 
values) from the look up table 1 120 to generate a mixer sample. The mixer 
sample includes a mixer in-phase sample and a mixer quadrature sample. The 
mixer circuit 1130 includes mixer in-phase and quadrature circuits 1 132 and 1334 
to generate the mixer in-phase and quadrature samples, respectively. 

[0099] Figure 1 IB is a diagram illustrating the carrier NCO base circuit 

1114 shown in Figure 2 according to one embodiment of the invention. The 
carrier NCO base circuit 1114 includes a carrier increment register 1 140, an adder 
1 150, and a carrier accumulating register 1 160. 

[00100] The carrier increment register 1 140 stores a carrier increment value 

provided by the processor 150 at a fo/4 frequency. The adder 1 1 50 adds the carrier 
increment value to the carrier NCO value stored in the accumulating register 1 160 
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to produce a sum. The sum is then stored in the accumulating register 1 160. The 
accumulating register 1 160 stores the sum generated by the adder 1 150 at a f 0 /4 
frequency. 

[00101] Figure 12 is a diagram illustrating the mixer circuit 1130 shown in 
Figure 11 according to one embodiment of the invention. The mixer circuit 1 130 
includes a mixer in-phase circuit 1210 and a mixer quadrature circuit 1220. 

[001 02] The mixer in-phase circuit 1210 generates an in-phase mixer 

sample I m from the in-phase and quadrature demodulated samples Id and Q d as 
follows: 

I m = Id*cos - Q d *sin (6) 

[001 03] The mixer quadrature circuit 1210 generates a quadrature mixer 
sample Q m from the in-phase and quadrature demodulated samples Id and Qd as 
follows: 

Q ra = Id*sin + Q d *cos (7) 

[001 04] where sin and cos are the sine and cosine values provided by the 
two registers 1125 and 1127, respectively. The I m and Q m are the results of 
complex multiplications between the Id, Qd with the sine and cosine values. 

[00105] The mixer in-phase circuit 1210 includes two logic circuits 1212 

and 1214 and an adder 1216. Each of the logic circuits 1212 and 1214 essentially 
performs a multiplication between the 6-bit demodulated sample and the sine or 
cosine value to generate an 8-bit product considering the range of value at the 
input and output and the coding method used. The multiplexer is a simplified set 
of logic gates. The adder 1216 adds the two 6-bit products to provide the in-phase 
mixer sample according to equation (6). The mixer quadrature circuit 1220 
includes two logic circuits 1222 and 1224 and an adder 1226. The two logic 
circuits 1222 and 1224 are the same as the logic circuits 1212 and 1214. The 
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adder 1226 adds the two 6-bit products to provide the quadrature mixer sample 
according to equation (7). 

[00106] Figure 1 3 is a diagram illustrating the epoch processing circuit 260 

shown in Figure 2, which controls the I and d memory circuits according to one 
embodiment of the invention. The epoch processing circuit 260 includes in-phase 
and quadrature memory circuits 1310 and 1320, an epoch control circuit 1330, and 
a multiplexer 1340. 

[00 1 07] Each of the in-phase and quadrature memory circuits 1310 and 

1320 accumulates the corresponding mixer samples over an epoch interval. The 
in-phase and quadrature memory circuits 1310 and 1320 are essentially identical 
except that the input for the in-phase memory circuit 1310 is the mixer in-phase 
sample and the input to the quadrature memory circuit 1320 is the mixer 
quadrature sample. The epoch control circuit 1330 generates an epoch control 
signal to the in-phase and quadrature memory circuits 1310 and 1320 indicating 
an end of an epoch. The multiplexer 1340 selects one of the in-phase and 
quadrature memory circuits 1310 and 1320 to be read by the processor 150. 

[00108] Figure 14 is a diagram illustrating the memory circuit 1310 shown 

in Figure 13 according to one embodiment of the invention. The memory circuit 
1310 includes an accumulating memory 1410, four registers 1412, 1414, 1425, 
and 1435, an address counter 1420, an adder 1430, a buffer memory 1440, a 
register 1445, and a gating circuit 1450. 

[00109] The accumulating memory 1410 stores P sums of the mixer 

samples during an epoch interval as provided by the epoch control circuit 1330 
(Figure 13). The mixer samples arrive at the accumulating memory 1410 at the 
sampling clock frequency of 24*f 0 , or every 40.72 nsec for a nominal frequency f 0 
of 1.023 MHz. Each block of mixer samples includes the complex mixing of the 
22-phase block of the input samples and the 22-phase block of the PN code 
samples. For the entire epoch interval which corresponds to 1023/1 1 = 93 blocks 
of 22-phase blocks of the input samples, the accumulation essentially adds the 22- 
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phase result blocks for 93 times. The value of the mixer samples has a range of {- 
88, + 88}. The range of the epoch result is therefore equal to +/- 88 x 93 = +/- 
8184. This range requires a word size of 14 bits including the sign hit. Each 
epoch also involves 12 satellite channels. To accumulate 22-blocks for all 12 
channels, the total number of epoch values stored in the accumulating memory 
1410 is 264. The accumulating memory 1410 is therefore organized as 512 x 16 
to accommodate 264 x 14 epoch results. In one embodiment, the accumulating 
memory 1410 is implemented as a dual-ported memory to allow simultaneous 
read and write. This allows reading the partial sum from the accumulating 
memory 1410 and writing the partial sum to the accumulating memory 1410 at the 
same address at the same time. 

100110] The address counter 1420 generates an address to the accumulating 

memory 1410 and the buffer memory 1440. The address counter 1420 is clocked 
by the sampling clock signal of 24* f 0 frequency. The address counter 1420 
sequences through the 12 satellite channels and the 22 phases. Therefore, the 
address counter 1420 generates the address modulo 12x22 = 264. 

[00111] The adder 1430 adds a mixer sample to the sum stored in the 

accumulating memory 1410. The result of the adder 1430 is written to the 
accumulating memory 1430. This result is read out in the next cycle to continue 
accumulating the mixer samples over the epoch interval. 

[00112] The buffer memory 1440 stores the P sums transferred from the 

accumulating memory 1410 at the end of each epoch interval. The contents of the 
buffer memory 1440 are read by the processor 150 via the multiplexer 1340. In 
one embodiment, the buffer memory 1440 is a dual-ported memory to allow 
simultaneous writing and reading. 

[00113] The registers 1412, 1414, 1425 and 1435 are clocked by the 

sampling clock signal at 24* f 0 frequency to synchronize the latching of the 
address and data for the accumulating and buffer memories 1410 and 1440. 
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[00114] The register 1445 synchronizes the epoch control signal with the 
sampling clock signal at 24*f 0 frequency. The gating circuit 1450 gates the partial 
sum from the accumulating memory 1410 with the epoch control signal so that 
when the accumulating memory 1410 is in the write mode, the buffer memory 
1440 is available for read and vice versa. 

[001 1 5] While this invention has been described with reference to 
illustrative embodiments, this description is not intended to be construed in a 
limiting sense. Various modifications of the illustrative embodiments, as well as 
other embodiments of the invention, which are apparent to persons skilled in the 
art to which the invention pertains are deemed to lie within the spirit and scope of 
the invention. 
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